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(57) Abstract: A method for playing back a program which includes one or more interactive 
applications. A program which is stored, either in the form of a data stream or as a set of files 
is played back from a storage device. Wbenplaybadc is started, applicatioiis .wiuch are delected 
are launched Applications are detiected in the playback of pushed content when they become 
available in the playback stream. Applications are detected in die playback of puUed content 
by comparing the validity ranges of the apf^caiions to a current playback index. When special 
playback modes are used, signals which affect the lifecyde of an apfdication are detected aiKl 
. corresponding signals are generated to maintain die proper state of the ai^cation. During these 
special plajfback modes, these vaiious ootificatioa signals may be conweyed to applicatioiB which 
are configured to operate during these modes. Applications which are not con^^ured to operate 
during these special playback modes may be terminated when the special modes are initiated and 
restarted when the special modes end. 
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m llK: PLAYBACK OF INTKKArnVK rKO( .'RAMS 



\ > nACKGROIINDOFTHE INVENTION 

I- Field of the [nvemion 

The invention relates uenerally lo broadcast television systems and more particularly to a system and 
method for playinp back programs which.havc been stored on the storage device of an interactive lelcvision system 
1 0 receiver, wherein the programs contain one or more interactive applications. 

2. Description of Related Art 

Interactive television systems provide a means to deliver interactive content as Well as ordinary television 

audio and video to a large number of subscribers. Programs brg^dcast by these systems may incorporate television 
1 5 audio and video, still images, text, interactive graphics and applications, and many other components. The 

interactive content of the interactive television signal may therefore include application code, data associated with 

the audio and video, control signals, raw data and iiiany other types of information. 

Intqactive content siich as application code or information relating to television programs is usually 

broadcast in a repeating format. ]n other words, each piece of information is broadcast a first lime, then each is 
20 transmitted a second time, and so on. The cycle is repeated so that each piece of interactive data is transmitted, for 

example, every ten seconds. The pieces of information which are broadcast in this manner form what is referred to 

as a ••canmsel." The sequence of information that makes iip the carousel can be prepared in advance, or it can be 

determined '*on the fly/* 

Broadcast systems (e.g., interactive television systems) transmit information in a carousel format in order 

25 to allow receivers in the system to selectively obtain panicular pieces of information in the carousel without 
requiring a return path from the receivers to the server. If a particular receiver needs a panicular piece of 
information, it can simply wait until next rime that piece of information is broadcast to obtain the information. If 
the information were not cyclically broadcast, the receiver would have to transmit a request for the information to 
the server, thus requiring a return path. Other receivers in the system can operate in the same maimer, each receiver 

30 waiting for the infomiation it needs, and then using only that infoimation. By en^>loying carousels to broadcast 
information, the S3fstem eliminates the need to connect each of the receivers with the server and iurther eliminates 
the need for the server to process individual requests for information. Generally, a broadcast signal may inchide a 
nimnber of programs which in turn may include a number of audio/video streams and/or data streams. Data streams 
may be used to cany data such as interactive application data, subtitle information, or other data. 

^5 The pieces of information, or data objects, in a carousel are often intended to be combined to form a single 

program. This program may also contain streaming data such as audio or video. For example, an interactive 
television game show may combine television audio and video with interactive content such as application code 
which allows users to answer questions. Another example would be a news program which combines audio and 
video with application code that inseru current stock prices in a banner at the bonom of the screen. It is to be 

40 understood that the term 'program * as used herein refers to any broadcast material including television shows. 
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S|>onini! cvcnis. news proj>Tan^^. movies, or any other lypc bV broadcast maieriai. or segment oi' the siiow. event, 
program, movie, or other material. The program may include only audio, video, data, or any combination ihereol'. 
The program may be only a portion of a television show or broadcast (e.g.. without commercials, or missing a 
portion of the beginning or end) or rnay be more than one show, or include commercials, for example. 
5 Program content received in a broadcast system is normally inteiided to be consumed immediately. It is 

nevertheless possible to record this content for later playback. The broadcast information can be recorded "as is" 
(i.e.. as the stream of data n-ansmincd to the receiver,) or it niay be recorded as a set of files thai can be accessed 
randomly instead of sequentially. If the information is recorded as a data stream, the data may be referred to as 
"pushed" data since the receiver must play the information back as a data stream - it caimot retrieve particular data 

10 objects out of order. Data objects which are recorded as a set of files can be individually retrieved, and may 
therefore be rcfened to as '"pulled** data: 

Regardless of whether an interactive programi is stored as pushed content or pulled content, there may be 
difficulties in playing back the recorded program, since it was originally intended for immediate consumption. 
Although it may be a relatively simple maner to play back the entire program from stan to fmish, just as it was 

15- originally provided to a user, the usfer may wish to use a special mode, such as pausing, fast- forwarding, reversing, 
or jumping to particular points in the program when it is replayed. Because the program may include different 
interactive applications which are in various states throughout the program, it is necessary to maintain the proper 
states for these applications, even when parts of the program are skipped in special playback modes. Further, the 
appHcatioiis may interact with other data objects, so in a special playback mode it may be necessary to generate 

20 . signals that would not otherwise be generated. 

SUMMARY OF THE INVENTION 
One or more of the problems outlined above may be solved by various embodiments of the invention. 
One embodiment comprises an interactive television receiver which is coupled to a storage device. The receiver is 

25 coupled to a broadcast network and configured to receive a signal corresponding to a program. The signal contains 
pushed interactive television data. The receiver is configured to store the pushed data, either as pushed content or 
as. pulled content, on the storage device. When the program is played back from the storage device, the receiver is 
configured to launch apphcations which are detected in the program. If the program is stored as a stream of data/ ^ 
an application may be detected by receiving an indication that it is available. If the program is stored as a set of 

30 . files, an application may be detected by comparing the validity range of the apphcation to a current playback index 
for the program. If special playback modes are used, the receiver is configured to determine whether the program 
would generate signals during the portion of the program skipped during special mode operations and to generate 
corresponding notifications if necessary. The receiver may also bexonfigured to terminate and restart applications 
which are not configured to operate in special playback modes. 

35 One embodiment comprises a method for playing back a program which includes one or more interactive 

applications. A program is stored, either in the form of a data stream or as a set of files containing the data objects 
which make up the program. When playback is staned, applications which are detected are launched. Applications 
are detected in the playback of pushed content when they become available in the playback stream. Applications 
are detected in. the playback of pulled content by comparing the validity ranges of the applications to a current 
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pljyback index. When special pbybuck motlcs are used, sicnals which alTcci ihc lilccycic of an applicaiion aie 
delected and eonespondini: signals are generated lo noiit'y the application lu allow it lo maintain its pruper state. 
Durinu these special playback modes, these various notification signals may be conveyed to applications which are 
conl'igured to operate during these modes. Applications which are not configured lo operate during these special 
5 playback riiodes may be terminated when the special modes are initiated and restarted when the special modes end., 

BRIEF DESCRIPTION OF THE DRAWINGS 
Other objects and advantages of the invention will become apparent upon reading the following detailed 
description and upon reference to the accompanying drawings in which: 
1 0 Fig. 1 is a functional block diagram of an interactive lelevisioii system. 

Fig. 2 is a diagram illustrating the structure of a carousel and a conesponding data stream. 
Fig. 3 is a diagram illustrating the interrelation of data objects in one program. 
Fig. 4 is a flow diagram illustrating one embodiment of the present method. 

Fig. 5 is a flow diagram illustrating an embodiment of the present method in which a program has been 
1 5. stored in a data stream. 

Fig. 6 is a flow diagram illustrating an embodiment of the present method in which a program has been 
stored as a set of files. 

While the invention is susceptible to various modifications and alternative forms, specific embodiments 
thereof are shown by way of example in the drawings and will herein be described in detail. It should be 
20 understood, however, that the drawings and detailed description thereto are not intended to limit the invention to 
the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and 
alternatives falling within the spirit and scope of the present invention as defined by the appended claims. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
25 Broadly speaking, the invention comprises an improved system and method for replaying stored 

interactive programs, wherein the programs are originally intended to be consumed as pushed broadcast data. 
While many embodiments of the iiivention are possible, the following description focuses primarily on one 
embodiment which is implemented in an interactive television system. This description is intended to be . 
illustrative rather than limiting. 
30 Referring to Fig. 1, a functional block diagram of an interactive television system 10 is shown. Interactive 

television system 10 generally comprises a broadcast station 12 and a receiving station 14 coupled to the broadcast 
station by a broadcast medium 13. In this figure, broadcast medium 13 is depicted as a satellite transmission 
network. Tlie broadcast medium may, in other embodiments; comprise other transmission means such as cable, 
telco, MMDS (microwave) and terrestrial transmission media. Broadcast station 12 is coupled to a program source 
35 15 which is configured to provide the data which foims the program. Receiving station 14 includes a receiver 18 
which is coupled to a storage device 16. Storage device 16 is configured to store the program data. Receiving 
station 14 also includes a television 17 which is used to present the program to a user. 

in one embodiment, the data objects of a program which is to be broadcast from broadcast station 12 to 
receiving station 14 are stored in one or more program sources 15. The data objects may be stored separately (e.g.. 
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as indcpendcmly accessible files. > or ihcy may be stored as a preeonsirucied data stream. Il should be noied that ilie 
program may also comain streams of data te.i:.. audio and videos which are m>t transmilied as daia ohjecls. If the 
data objects of the program are stored as individual files, they are retrieved by broadcast station 12 from program 
source 15 to be sequentially broadcast. If ihc program is stored as a prcconsimcicd data stream, the stream can be 
5 broadcast essentially as ii is stored. Tlie program data may be compressed and control information may be added to 
' the data for use by the interactive television system. Tlie program data and any additional information is then 

convened by broadcast station 12 to a formal suitable for transmission over broadcast medium 13. In this particular 
embodiment, the data is fonnancd into packets which can be transmincd over a digital satellite network. These 
packets may be multiplexed with other packets for transmission. 
10 Broadcast station 1 2 nansmils the data objects of the program in a carousel which is cyclically transmitted 

to receiving station 14. This produces a stream of data in which each data object is transmined rcpeaiedly. It 
should be noted that the broadcast medium (a digital satellite network in this embodiment) can supix>Tt a number of 
different channels, and that different carousels (and corresponding data streams) can be concuircntly broadcast on 
these channels. When receiving station 1 4 receives ihc data stream, the program contained in the data stream may 
1 5 be played immediately or it may be recorded. If the program is to be played immediately; receiving station 14 

converts the data stream back into the data objects and uses them as necessary in the program. If the program is to 
be stored, it may be parsed into the individual data objects and stored as a set of files, or it may be stored as a data 
stream, as it was received. If the program is to be stored, it is conveyed to storage device 16. Data, streams which 
arc included in the program (e.g., audio or video streams) may also be stored on storage device 1 6. The program 
20 maybcstoredwhcther it is immediately played or not. 

Receiver 1 8 is typically implemented in a set-top box which is connected to television 1 7. The set-top box 
incorporates a control unit (e.g., a microprocessor,) a memory, and other components which are necessary to select 
and decode the received interactive television signals. Because the basic components and feamres of set-top boxes 
are known, they will not be discussed m detail here. Typically, set-top boxes are designed to provide the necessary 
25 interactive functionality at a minimal cost. Consequently, they normally have a limited amount of memory and no 
storage devices (e.g., hard disk drives.) While the memory is sufficient to execute interactive applications, il is not 
adequate to store the applications for an indefinite period of time. Therefore, the applications do not normally 
remain in memory when they are no longer being executed. 

Even if the memory of the set-top box were large enough to store sonic interactive applications, it might 
30 still be too smaU to accommodate a program which includes large amounts of audio or video dkta, application code, 
or other information. In one embodiment of the present system, storage device 1 6 is coupled to the set-top box to 
provide sufficient storage to record programs that will not fit in the hmited amount of memory, in the set-top box, 
Storage device 16 may comprise any suitable storage device, such as a hard disk drive, a recordable DVD drive or 
optical disk drive. It can be internal to the set-top box, or it may be connected externally. Storage device 16 can be 
35 conncctied permanently or removably to the set-top box. 

Referring to Fig. 2, the stmcture of a carousel (and a corresponding data stream) which is transmincd to 
the receiver is illustrated. Carousel 24 comprises data objects 21-23 and carousel information 20. Data objects 21- 
23 arc remeved from a program source as described above. Carousel information 20 is provided by the broadcast 
station and mav contain information such as the carousel ID and version number, a file access table or directory for 
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• the carousel, and various other inlormation. I Ponions of this information, such as the file access tabic, are not 
necessary in programs which are intended for immediate consumption.) The broadcast station transmits carousel 
information 20 and data objects 2 1 -23 sequentially. The first instance of the transmission of carouser24 is 
indicated by 25. After the bi oadcast station has completed transmission of the first instance of carousel 24. it is 

5 transmitted again, as indicated by 26. The successive, cyclical transmissions of carousel 24 indicated by 25-29 
form data stream 30. Transmission of the carousel may be repeated indefinitely. 

As mentioned above, the data objects which comprise a program may include application code, audio and 
video data, control signals, raw data and other types of information. If the program is to be imniediately consumed 
(i.e., presented to the user,) the data must be parsed to extract the data objects from the strcariL When the necessary 

10 data objects have been extracted, the program is played. The data objects are used as defmcd in the program. For 
example^ any applications which need to be executed are launched, any audio or video data which needs to be 
presented to the user is played or displayed, any signals which need to be produced arc generated^ and so on. The 
program is presented to the user, typically via a television 1 7, and is consumed- Regardless of whether or not the 
program is immediately prescnied to the user, it can also be stored. The storage device can be used to store 

15 programs "as is" (i.e., as a data stream which is essentially the same as that received in the broadcast signal) or as a 

• set of files that can be individually accessed or updated. In either case, the recorded program can be played back. 
The present system and method are employed to facilitate and/or enable the use of playback features such as trick 
play modes when viewing the recorded prograni. To illustrate the advantages of the system and method, it may be 
useful to examine the structive of a program. 

20 As noted above» a program may consist of a number of data objects and data streams. These data (^>iccts 

may reference each other, they may trigger certain events, or they may be triggered by certain events. Interactive 
applications which are contained in the program may be started and stopped while the prograni is being played. If 
the data objects are stored as files, the validity ranges associated with the Hies correspond to the times during which 
they are available to the program. For example, as long as a data object is being broadcast as part of a carousel, that 

25 data object, is valid. When the carousel (hence the data object) is no longer being broadcast, the data object is no 
longer valid. Thus, a start time and an end time defining the validity range of the data object can be detcimined by 
the receiver and stored with the corresponding file. 

It should be noted that, although the present disclosure is directed primarily to an interactive television 
system which is configured to play back a previously stored broadcast program, the system and method presented 

30 herein are equally applicable to the playback of programs which are stored by other means. For example, pushed 
content which could be broadcast may also be stored offline (e.g., on a DVD) and later distributed to the user for 
playback. The program could also be played back from an on-demand server (e.g., playing video on demand.) 

Referring to Fig. 4, a flow diagram illustrating one method employed by the interactive television system 
described above is shown. After the program is recorded on the storage device, playback of the program is 

35 initiated. The receiver is configured to detect applications in the recorded data. When an application is detected in 
the program, the application is launched. The manner in which applications are delected in. the program depends 
upon how the program was stored. 

Referring to Fig. 5, a flow diagram illustrating the detection of an appUcation in a system configured to 
receive a program as a data stream is shown. If the application was recorded as a data stream, the receiver detects 
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an application by examining the sequential stream of data which is pbvod hack.lrom the storaue device. When the 
stream contains inl'omiatton indicating that the apphcaiion is uvadable. ihe receiver detects this intorniation and 
thereby detects the application. The application is then launched. 

Refcrrine to Fig. 6, a flow diagrann illusrratine ihc detection ol an application in a system configured to 
5 receive a program as a set of files is shown. If the program was recorded as a sci of files, the detection of 

applications in the program proceeds in a different manner. When playback of the program is initiated, the receiver 
examines the stored files. In one embodiment, the application files include information defining validity ranges for 
the corresponding applications. The receiver compares the validity range for each application to a current playback 
index. If the current playback index falls within the validity range of a panicular application, that application is 

10 considered to have been detected, and is launched. 

The cuncnt playback index mentioned above is simply a rebtive time index used in the playback of the 
program. The validity ranges mentioned above comprise data which, in one embodiment, is determined by the 
receiver when the program is recorded. (It should be noted that in some embodiments, particularly those in which 
the program is played back from a prerecorded medium such as a DVD. the validity .range may be predetermined 

1 5 and provided with the corresponding data object.) The validity range consists of a beginning time and an end time. ■ 
The application is intended to be executed (or to be available for execution) between the beginning and end times. 
Thus, if playback of a program is initialed and the current playback index is within the validity range of an 
application, the receiver will launch the application. 

This may be illustrated in the following example. Assume a program is broadcast from 1:00 to 2:00. The 

20 program contains an application which is valid during the entire program. If a user recoirds the program from 1 :30 
to 2:30, the apphcation is stored with a validity range from 1 :30 to 2:00. or 30 minutes from the beginning of the 
recording. When the program is played back, the application will be valid for the fust 30 minutes of the recording. 
If the user starts playback of the program and fast-forwards for 40 minutes, when normal playback is restimed, the 
application will no longer be valid and will not be restarted. 

25 Whether the program was stored as a data stream or as a set of files, the detection of applicatioiis continues 

as the program is played back. Thus, as new applications are detected, they are launched: It should be noted that 
the capabilities of the receiver and the policies implemented in the execution enviromnent of the receiver .determine 
the efifect on a currently executing application of launching another application. If the receiver is capable of 
executing only one application at a time, a ciurently executing application may have to.be killed or suspended 

30 before another s^licatibn can be launched. It may or may not be necessary to imload the first application irom 
memory while thesecoiul application is executing. If the receiver can simultaneously execute more than one 
application, llien the second application may be launched while the fust application continues to run. The receiver 
may, however, implement a policy which prohibits executing applications simultaneously. The receiver may 
therefore be required to kill or suspend the first application upon launching the second, even though the receiver is 

35 capable of executing both. 

As mentioned above, when a user plays back a program, he or she may wish to use special playback 
modes rather than simply playing the program back sequentially (i.e.. in a normal play mode.) The special modes 
may include trick play modes, such as fast forward, slow motion and rewind, and rnay also include jump, seek and 
pause featiues. When special play modes are used, the program moves from a first point at which an application is 



in a firsi stale exccuiihi:) lo a second point at which ihc application should be in a second state tc.u.. 
terminated or suspended.) Because the portion ol the program between the first and second points is hot played (or 
executed.) certain signals and events which would normally cause an application lo modify its state arc not 
encountered. Care must therefore be taken to ensure that the lifecycle of the application rcsultini: from use of the 
5 special play mode corresponds to the position in the program after the special play mode is stopped. ("Lifecycle" is 
used here 10 indicate the state of the application, including bDi not limited to states of execution, such as launch, 
suspend, resume and terminate, and any internal states defined by the application during execution.) 

Because the application may skip an event (a signal or set of conditions) which should nigger a change of 
stale in the application, it may be necessary to take some action to produce the change of state. In one embodiment. 
10 the receiver is configured lo determine whether any events would occur beitwecn initiation of the special play mode 
and termination of the special play mode which would affect the lifecycle of the application. These events may 
include the receipt of particular signals or notifications, the existence of particubr conditipns, or other factors. The 
receiver is configured lo generate signals or notifications corresponding to the skipped events, and to convey ihcsc 
signals or notifications to the application to modiiy its state. These signals and notifications may include kill 
1 5 signals, notifications that special play modes have been started or stopped, notifications that seeks have been 

initiated, module or trigger notifications, accelerated version notifications, and other signals or notifications that 
may be useful in playing back the program. It should be noted that the generation of signals and notifications may 
be dependent upon the existence of related conditions. For example, modules and triggers may be flagged to 
indicate whether notifications relating thereto should be provided to the applications. Generation of signals and 
20 Dotincations may also be conditioned upon whether they occiir within a conesponding validity range. 

The receiver is also configured to generate signals associated with application chaining and to provide the 
signals to applications in the program. "ChaiDing- refers to the execution of different applications in the program 
. in relation to each other. The chaining policy defines how execution of certain applications affects other 
applications. For example, if a first application is currently executing and a second application is deteaed and 
25 launched, the chaining policy may dcfme whether the first application is terminated or suspended or, if the receiver 
can concuirently execute both applications, whether they should both be executed at the same time. It should be 
noted that the capabilities of the receiver may affect the chaining policy, smce the policy is implemented in the 
receiver. (For example, if the receiver can only execute one apphcaiion at time, the chaining policy cannot have 
two applications executing concurrently.) 
30 The signals provided by the receiver to the applications are typically generated sequentially (in the order 

they would have occurred m a normal playback mode) because the state of aln application may depend on the order 
in which the sigiials are received. When the special play mode is a forward mode (e g-, fast forward.) the signals 
and notifications generated by the receiver arc provided to the applications, in their normal sequential order. When 
the special play mode is a reverse mode (e.g., rewind,) the signals may have to be generated in reverse order, or the 
35 receiver may have to generate signals which "undo," or reverse the effect of, the forward-play signals. 

It should be pointed out that some appUcations may depend on live data reception to maintain their state. 
When a special playback mode is used to cause an application to move to a particular point in the playback of the 
program, precautions may need to be taken to ensure that the application is in the appropriate slate after the 
program rewms to a normal playback mode. This needs to be addressed for two different cases: cases in which 
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applications were authored wiih ihc iniciit that they would be recorded and played back: and cases in which 
applications were not intended to the recorded and replayed. 

In the first case, an application is produced with the knowledge that it maybe recorded and played back 
using special play modes. Siich an application would typically be designed to accept notifications of these special 
5 play modes and to accommodate them. For example, an application caii be configured to generate a query to • 
determine the current position iri the playback of the program. The application could then set its internal state 
according to the position in the program. 

In the second case, an application is produced with the intent that it will be consumed as it is received. 
The application is not designed to jump from one position to another in the program except as the program 

10 progresses in a noTmal play mode. If a special play mode is initiated while such an application is executing^ the 
application can simply be terminated and restaned at the new position in the program. The applicatioii may be 
allowed to save information (e.g., state information) to persistent storage such as the storage device when it is 
tcminated.. It should be noted that the application may be removed from memory when it is teiminated, so it may 
have to be downloaded again from the data stream and restarted after the program has jumped to the new position. 

1 5 Because these two types of applications are handled differently when special play modes are initiated, it is 

contemplated that the applications will be configured to indicate to the receiver whether they are capable of 
handling special play modes. It is also conten^lated that some applications may be configtired to prevent certain 
special play modes. For exanqple, an aj^lication may be configured to prevent the user from rewinding or may 
allow the user to rewind only to certain positions, such as the beginnings of chapters. 

20 Whfle the present invention has been described with reference to particular embodinients, it will be 

imderstood that the embodiments are illustrative and that the invention scope is not limited to these embodiments. 
Many variations, modifications, additions and improvements to the embodiments described are possible. These 
variations, iiK>dificatioiis, additions and improvements may fall within the scope of the invention as detailed within 
the following claims. 
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WHAT IS CLAIMED IS: 

1. A method comprising: 

receiving a broadcast signal, wherein said broadcasi signal contains a program and wherein said program 
5 contains one or more interactive applications: 

storing said program on a storage device; 

iniitiating playback of said program from said storage device: and 

launching a first interactive application of said one or more interactive applications in response to 
detecting said first interactive application during said playback of said program. 

10 ^ 

2. The method of claim 1 wherein said program is stored on said storage device as it is received, wherein , 
detecting said first interactive application comprises detecting said first interactive application is available frotd an 
interactive application data stream of said program during said playback. 

15 3. The method of claim I wherein storing said program includes storing an interactive application data 

stream of said program, wherein said storing of said data stream comprises extracting from said program one or 
more data objects and storing said data objects on said storage device as a set of files, wherein initiating playback of 
said data stream comprises retrieving one or more of said set of files from said storage device and wherein detecting 
said one of said one or more interactive applications conqmses coinparing a validity range associated with said one 

20 of said one or more apptications to a current playback index and detecmuaing that said current playback index is 
within said validity range. 

A method comprising: 

providing a program stored on a storage device, wherein said program contains ah interactive application; 
initiating playback of said program from said storage device; 
laimching said interaaive application; 
initiating a special play mode of said program; and 

conveying a notification signal to said interactive application, during said special play mode. 
The method of claim 4 further comprising: 

initiating a special play mode of said program wherein during said special, play mode, a current playback 

index changes from a fust value to a secohd value; 
determining whether events, affecting the state of said interactive application would have been encountered 

in a normal play mode between said first value and said second value; 
generating signals corresponding to said events; and 
conveying said signals to said application. 

Tbemethod of claim 5 wherein said signals are generated sequentially according to the order of said 
corresponding events in a normal play mode. 
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7. The method of claim 4 wherein one or more of said notification signals are selected from the group 

consisting of: application kill signals; application launch signals: application pause signals: application resunoe 
signals; trick niode start notifications: trick nnode end notifications; seek notifications; module notifications; trigger 
notifications; and accelerated version notifications. 

8: The method of claim 4 further comprising said interactive application receiving an indication of a current 
position in said program and setting the internal state of said interactive application to correspond to. said current 
position. 

9. The method of claim 8 wherein said application receives said indication of said current position in said 
program while said program is in said special play mode. 

10. The method of claim 4 lunher comprising: 
initiating a special play mode of said program; 

conveying a kill signal to said interactive application in said program; 
terminating said special play mode; and 

launching an interactive application in response to detecting said interactive application is available; 

l .I. The method of claim 4 further comprising said interactive application: 

indicatiDg to a receiver on which said interactive application is executing whether said interactive - 

application is configured to operate when a special play mode is initiated; 
notifying said interactive application of said special play mode in response to detecting said interactive 

application is configured to operate during said special play mode; and 
terminating said interactive application when said special play mode is used in response to detecting said 

interactive apptication is not configured to opmic during said special play. mode. 

12. The method of claim 4 further compnsmg: 
broadcasting said program; 

receiving said program; and 

storing said fn-ogram on said storage device. 

13. A device comprising: 
a receiver; and 

a storage device coupled to said receiver; wherein said storage device is configured to store a program data 
stream including one or more interactive application data streams and to provide said program 
data stream to said receiver for playback; and 

wherein said receiver is configured to detect and latmch said one or more interactive applications. 
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14. 'ITic device ol' claim 13 wherein said receiver is contieiircd lo be coupled lo an intcraciive television 
system: wherein. said receiver is confiyurcd to receive said program data from said intcraciive television system; . 
and wherein said receiver is configured to store said program data in said storage device. 

5 15. The device of claim 13 wherein said storage device is configured to store said program data stream as.it is 
received; wherein said receiver is configured to receive said data stream and to determine when said one or more 
interactive applications are available in said data stream; and wherein said receiver is configured to launch said one 
or more interactive applications^ in response to detecting said one or more interactive applications are available. 

10 16. The device of claim 13 wherein said storage device is configured to store said program daD stream as a set 
of flics; wherein said receiver is configured to retrieve one of said set of files containing interactive applications; 
wherein said receiver is configured to compare validity ranges associated with said interactive applications to a 
current playback index; and wherein said receiver is configured to launch ones of said interactive applications for 
which said associated validity range includes said current playback index. 

15 

17. The device of claim 13 wherein said receiver is configured to play back said program using a special 
playback mode between a first playback index and a second playback index; wherein said receiver is conflgured to 
detennine whether one or more events affecting the state of said program would be encountered in a normal 
playback mode between said first playback index and said second playback index; wherein if said one or more 

20 events would be encountered in said normal playback mode, said receiver is configured to generate one or more 
signals iiidicative of said one or more events and to provide said one or more signals to said program. 

18. The device of claim 13 wherein said receiver is configured to receive a notification from a first interactive 
application of said one or more interactive apphcations indicating whether said first interactive application is . 

25 configured to operate in special playback modes; wherein if said first interactive applicadon is configured to 

operate in special playback modes, said receiver is configured to provide a notification of said special playback ^ 
mode to said first interactive appHcation when said special playback mode is used; and wherein if said first 
interactive application is not configured to operate in special playback modes, said receiver is configured to 
terminate said first interactive apphcation when said special playback mode is used. 

30 

19. The device of claim 1 8 wherein when use of said special playback mode is stopped, said receiver is . 
configured to restart said first interactive applicatioiL 

20. The device of claim 19 wherein said receiver is configured to res tan said first interactive application by 
35 extracting said first interactive application from a data stream. 

21 . The device of claim 1 3 wherein said receiver is configured to receive an indication from one of said one or 
more applications which indicates that a special playback mode can be used by said receiver. 
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